home *** CD-ROM | disk | FTP | other *** search
/ Personal Computer World 2009 February / PCWFEB09.iso / Software / Freeware / Gobby 0.4.7 / gobby-0.4.7.exe / {app} / share / gtksourceview-2.0 / language-specs / vhdl.lang < prev    next >
Extensible Markup Language  |  2008-09-09  |  8KB  |  248 lines

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3.  
  4.  Author: J├╝rg Billeter <j@bitron.ch>
  5.  Copyright (C) 2005 J├╝rg Billeter <j@bitron.ch>
  6.  
  7.  This library is free software; you can redistribute it and/or
  8.  modify it under the terms of the GNU Library General Public
  9.  License as published by the Free Software Foundation; either
  10.  version 2 of the License, or (at your option) any later version.
  11.  
  12.  This library is distributed in the hope that it will be useful,
  13.  but WITHOUT ANY WARRANTY; without even the implied warranty of
  14.  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  15.  Library General Public License for more details.
  16.  
  17.  You should have received a copy of the GNU Library General Public
  18.  License along with this library; if not, write to the
  19.  Free Software Foundation, Inc., 59 Temple Place - Suite 330,
  20.  Boston, MA 02111-1307, USA.
  21.  
  22. -->
  23. <language id="vhdl" _name="VHDL" version="2.0" _section="Sources">
  24.   <metadata>
  25.     <property name="mimetypes">text/x-vhdl</property>
  26.     <property name="globs">*.vhd</property>
  27.     <property name="line-comment-start">--</property>
  28.   </metadata>
  29.  
  30.   <styles>
  31.     <style id="comment" _name="Comment" map-to="def:comment"/>
  32.     <style id="string" _name="String" map-to="def:string"/>
  33.     <style id="character" _name="Character" map-to="def:character"/>
  34.     <style id="keyword" _name="Keyword" map-to="def:keyword"/>
  35.     <style id="type" _name="Type" map-to="def:type"/>
  36.     <style id="boolean" _name="Boolean value" map-to="def:boolean"/>
  37.     <style id="base-n-number" _name="Base-N Integer" map-to="def:base-n-integer"/>
  38.     <style id="real" _name="Real number" map-to="def:floating-point"/>
  39.     <style id="number" _name="Number" map-to="def:number"/>
  40.   </styles>
  41.  
  42.   <default-regex-options case-sensitive="false"/>
  43.  
  44.   <definitions>
  45.  
  46.     <context id="line-comment" style-ref="comment" end-at-line-end="true">
  47.       <start>--</start>
  48.       <include>
  49.         <context ref="def:in-line-comment"/>
  50.       </include>
  51.     </context>
  52.  
  53.     <context id="string" style-ref="string" end-at-line-end="true">
  54.       <start>"</start>
  55.       <end>"</end>
  56.     </context>
  57.  
  58.     <context id="character" style-ref="string">
  59.       <match>'.'</match>
  60.     </context>
  61.  
  62.     <context id="keywords" style-ref="keyword">
  63.       <keyword>access</keyword>
  64.       <keyword>after</keyword>
  65.       <keyword>alias</keyword>
  66.       <keyword>all</keyword>
  67.       <keyword>architecture</keyword>
  68.       <keyword>array</keyword>
  69.       <keyword>assert</keyword>
  70.       <keyword>attribute</keyword>
  71.       <keyword>begin</keyword>
  72.       <keyword>block</keyword>
  73.       <keyword>body</keyword>
  74.       <keyword>buffer</keyword>
  75.       <keyword>bus</keyword>
  76.       <keyword>case</keyword>
  77.       <keyword>component</keyword>
  78.       <keyword>configuration</keyword>
  79.       <keyword>constant</keyword>
  80.       <keyword>disconnect</keyword>
  81.       <keyword>downto</keyword>
  82.       <keyword>else</keyword>
  83.       <keyword>elsif</keyword>
  84.       <keyword>end</keyword>
  85.       <keyword>entity</keyword>
  86.       <keyword>exit</keyword>
  87.       <keyword>file</keyword>
  88.       <keyword>for</keyword>
  89.       <keyword>function</keyword>
  90.       <keyword>generate</keyword>
  91.       <keyword>generic</keyword>
  92.       <keyword>group</keyword>
  93.       <keyword>guarded</keyword>
  94.       <keyword>if</keyword>
  95.       <keyword>impure</keyword>
  96.       <keyword>in</keyword>
  97.       <keyword>inertial</keyword>
  98.       <keyword>inout</keyword>
  99.       <keyword>is</keyword>
  100.       <keyword>label</keyword>
  101.       <keyword>library</keyword>
  102.       <keyword>linkage</keyword>
  103.       <keyword>literal</keyword>
  104.       <keyword>loop</keyword>
  105.       <keyword>map</keyword>
  106.       <keyword>new</keyword>
  107.       <keyword>next</keyword>
  108.       <keyword>null</keyword>
  109.       <keyword>of</keyword>
  110.       <keyword>on</keyword>
  111.       <keyword>open</keyword>
  112.       <keyword>others</keyword>
  113.       <keyword>out</keyword>
  114.       <keyword>package</keyword>
  115.       <keyword>port</keyword>
  116.       <keyword>postponed</keyword>
  117.       <keyword>procedure</keyword>
  118.       <keyword>process</keyword>
  119.       <keyword>pure</keyword>
  120.       <keyword>range</keyword>
  121.       <keyword>record</keyword>
  122.       <keyword>register</keyword>
  123.       <keyword>reject</keyword>
  124.       <keyword>report</keyword>
  125.       <keyword>return</keyword>
  126.       <keyword>select</keyword>
  127.       <keyword>severity</keyword>
  128.       <keyword>signal</keyword>
  129.       <keyword>shared</keyword>
  130.       <keyword>subtype</keyword>
  131.       <keyword>then</keyword>
  132.       <keyword>to</keyword>
  133.       <keyword>transport</keyword>
  134.       <keyword>type</keyword>
  135.       <keyword>unaffected</keyword>
  136.       <keyword>units</keyword>
  137.       <keyword>until</keyword>
  138.       <keyword>use</keyword>
  139.       <keyword>variable</keyword>
  140.       <keyword>wait</keyword>
  141.       <keyword>when</keyword>
  142.       <keyword>while</keyword>
  143.       <keyword>with</keyword>
  144.       <keyword>note</keyword>
  145.       <keyword>warning</keyword>
  146.       <keyword>error</keyword>
  147.       <keyword>failure</keyword>
  148.       <keyword>and</keyword>
  149.       <keyword>nand</keyword>
  150.       <keyword>or</keyword>
  151.       <keyword>nor</keyword>
  152.       <keyword>xor</keyword>
  153.       <keyword>xnor</keyword>
  154.       <keyword>rol</keyword>
  155.       <keyword>ror</keyword>
  156.       <keyword>sla</keyword>
  157.       <keyword>sll</keyword>
  158.       <keyword>sra</keyword>
  159.       <keyword>srl</keyword>
  160.       <keyword>mod</keyword>
  161.       <keyword>rem</keyword>
  162.       <keyword>abs</keyword>
  163.       <keyword>not</keyword>
  164.     </context>
  165.  
  166.     <context id="types" style-ref="type">
  167.       <keyword>bit</keyword>
  168.       <keyword>bit_vector</keyword>
  169.       <keyword>character</keyword>
  170.       <keyword>boolean</keyword>
  171.       <keyword>integer</keyword>
  172.       <keyword>real</keyword>
  173.       <keyword>time</keyword>
  174.       <keyword>string</keyword>
  175.       <keyword>severity_level</keyword>
  176.       <keyword>positive</keyword>
  177.       <keyword>natural</keyword>
  178.       <keyword>signed</keyword>
  179.       <keyword>unsigned</keyword>
  180.       <keyword>line</keyword>
  181.       <keyword>text</keyword>
  182.       <keyword>std_logic</keyword>
  183.       <keyword>std_logic_vector</keyword>
  184.       <keyword>std_ulogic</keyword>
  185.       <keyword>std_ulogic_vector</keyword>
  186.       <keyword>qsim_state</keyword>
  187.       <keyword>qsim_state_vector</keyword>
  188.       <keyword>qsim_12state</keyword>
  189.       <keyword>qsim_12state_vector</keyword>
  190.       <keyword>qsim_strength</keyword>
  191.       <keyword>mux_bit</keyword>
  192.       <keyword>mux_vectory</keyword>
  193.       <keyword>reg_bit</keyword>
  194.       <keyword>reg_vector</keyword>
  195.       <keyword>wor_bit</keyword>
  196.       <keyword>wor_vector</keyword>
  197.     </context>
  198.  
  199.     <context id="boolean" style-ref="boolean">
  200.       <keyword>false</keyword>
  201.       <keyword>true</keyword>
  202.     </context>
  203.  
  204.     <define-regex id="hexnum">[0-9a-f][0-9a-f_]*</define-regex>
  205.     <define-regex id="exponent">[Ee][+-]?[0-9][0-9_]*</define-regex>
  206.  
  207.     <context id="base-n-number" style-ref="base-n-number">
  208.       <match extended="true">
  209.         (?<![\w\.])
  210.         [0-9][0-9_]*\#\%{hexnum}(\.\%{hexnum})?\#\%{exponent}?
  211.         (?![\w\.])
  212.       </match>
  213.     </context>
  214.  
  215.     <context id="real" style-ref="real">
  216.       <match extended="true">
  217.         (?<![\w\.])
  218.         [0-9][0-9_]*\.[0-9][0-9_]*\%{exponent}?
  219.         (?![\w\.])
  220.       </match>
  221.     </context>
  222.  
  223.     <context id="number" style-ref="number">
  224.       <match extended="true">
  225.         (?<![\w\.])
  226.         [0-9][0-9_]*(E[+]?[0-9][0-9_]*)?
  227.         (?![\w\.])
  228.       </match>
  229.     </context>
  230.  
  231.     <context id="vhdl">
  232.       <include>
  233.         <context ref="line-comment"/>
  234.         <context ref="string"/>
  235.         <context ref="character"/>
  236.         <context ref="keywords"/>
  237.         <context ref="types"/>
  238.         <context ref="boolean"/>
  239.         <context ref="base-n-number"/>
  240.         <context ref="real"/>
  241.         <context ref="number"/>
  242.       </include>
  243.     </context>
  244.  
  245.   </definitions>
  246.  
  247. </language>
  248.